<template>
    <!-- 分享弹窗 -->
    <view @touchmove.prevent.stop class="share-popup">
        <u-popup :show="sharePopupShow" type="bottom" @close="sharePopupClose" overlayOpacity="0.8">
            <view @touchmove.prevent.stop>
                <view class="share-content">
                    <!-- #ifdef MP  -->
                    <view class="share-box">
                        <button class="share-btn" :plain="true" open-type="share">
                            <view class="text-[#07c160] iconfont iconweixin11"></view>
                            <text>分享给好友</text>
                        </button>
                    </view>
                    <!-- #endif -->

                    <!-- #ifdef H5 -->
                    <view class="share-box" @click="copyUrl">
                        <button class="share-btn" :plain="true">
                            <view class="text-[#07c160] iconfont iconfuzhilianjie"></view>
                            <text>复制链接</text>
                        </button>
                    </view>
                    <!-- #endif -->
                </view>
                <view class="share-footer" @click="sharePopupClose">
                    <text>取消分享</text>
                </view>
            </view>
        </u-popup>
        <u-popup :show="show" mode="center" :round="10" :closeable="true" @close="show = false" :safe-area-inset-bottom="false">
            <view class="dialog-popup">
                <view class="title">提示</view>
                <view class="message">您拒绝了保存图片到相册的授权请求，无法保存图片到相册，如需正常使用，请授权之后再进行操作。</view>
                <view class="action-wrap">
                    <view @click="closeDialog">取消</view>
                    <view>
                        <button type="default" class="authorization-btn" open-type="openSetting" @opensetting="closeDialog" hover-class="none">立即授权</button>
                    </view>
                </view>
            </view>
        </u-popup>
    </view>
</template>

<script setup lang="ts">
import { ref } from 'vue';
import { img, copy } from '@/utils/common';

const props = defineProps({
    copyUrl: { // 例 "/wap/addon/shop_fenxiao/pages/goods"
        type: String,
        default: ''
    },
    copyUrlParam: {
        type: String,
        default: ''
    }
})

const emits = defineEmits(['close'])

const sharePopupShow = ref(false);

// 复制
const copyUrl = () => {
    let data = ''
    if (props.copyUrl) {
        let pathName = location.pathname;
        let packageArr: any = ['/app/', '/addon/'];
        for (let i = 0; i < packageArr.length; i++) {
            if (pathName.indexOf(packageArr[i]) != -1) {
                pathName = pathName.substr(0, pathName.indexOf(packageArr[i]));
            }
        }
        data = location.origin + pathName + props.copyUrl + props.copyUrlParam;
    } else {
        data = location.origin + location.pathname + props.copyUrlParam;
    }
    copy(data, () => {
        sharePopupShow.value = false;
    });
}

const openShare = () => {
    sharePopupShow.value = true
}

const show = ref(false);

const closeDialog = () => {
    show.value = false;
}

const shareTop: any = ref(0)
/************ 获取微信头部-start ****************/
// 获取系统状态栏的高度
let menuButtonInfo: any = {};
// 如果是小程序，获取右上角胶囊的尺寸信息，避免导航栏右侧内容与胶囊重叠(支付宝小程序非本API，尚未兼容)
// #ifdef MP-WEIXIN || MP-BAIDU || MP-TOUTIAO || MP-QQ
menuButtonInfo = uni.getMenuButtonBoundingClientRect();
shareTop.value = menuButtonInfo.top + menuButtonInfo.height + 'px';
// #endif
/************ 获取微信头部-end ****************/

const sharePopupClose = () => {
    sharePopupShow.value = false;
    emits('close');
}

defineExpose({
    openShare
})
</script>
<style lang="scss" scoped>
.share-popup {
    :deep(.u-transition), :deep(.u-popup__content) {
        background-color: transparent;
    }

    .share-content {
        border-top-left-radius: 40rpx;
        border-top-right-radius: 40rpx;
        overflow: hidden;
        display: flex;
        display: -webkit-flex;
        -webkit-flex-wrap: wrap;
        -moz-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        -o-flex-wrap: wrap;
        flex-wrap: wrap;
        padding: 40rpx 15rpx;
        background-color: #fff;

        .share-box {
            flex: 1;
            text-align: center;

            .share-btn {
                margin: 0;
                padding: 0;
                border: none;
                line-height: 1;
                height: auto;
                background: none;

                text {
                    margin-top: 20rpx;
                    font-size: 24rpx;
                    display: block;
                    color: #333;
                }
            }

            .iconfont {
                font-size: 80rpx;
                line-height: initial;
            }

            .icon-fuzhilianjie,
            .icon-pengyouquan,
            .icon-haowuquan,
            .icon-share-friend {
                color: #07c160;
            }
        }
    }

    .share-footer {
        background-color: #fff;
        height: 90rpx;
        line-height: 90rpx;
        border-top: 2rpx solid #eee;
        text-align: center;
        font-size: 26rpx;
    }

}

.dialog-popup {
    width: 580rpx;
    background: #fff;
    box-sizing: border-box;
    border-radius: 10rpx;
    overflow: hidden;
    height: initial;

    .title {
        padding: 30rpx 30rpx 0 30rpx;
        text-align: center;
        font-size: 32rpx;
        font-weight: bold;
    }

    .message {
        padding: 0 30rpx;
        color: #666;
        text-align: center;
        line-height: 1.3;
        margin-top: 30rpx;
    }

    .action-wrap {
        margin-top: 50rpx;
        height: 80rpx;
        display: flex;
        border-top: 2rpx solid #eee;

        & > view {
            flex: 1;
            text-align: center;
            line-height: 80rpx;

            &:first-child {
                border-right: 2rpx solid #eee;
                color: #999;
            }

            button {
                border: none;
                line-height: 80rpx;
                padding: 0;
                margin: 0;
                width: 100%;
                height: 100%;
            }
        }
    }

    .authorization-btn {
        background-color: #07c160;
        color: #fff;
        font-size: 28rpx;
        border-radius: 0;
    }
}
</style>
